package com.zjy.system.service.impl;

import com.zjy.system.domain.Menu;
import com.zjy.system.mapper.MenuMapper;
import com.zjy.system.service.MenuService;
import com.zjy.basic.service.impl.BaseServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

/**
 * 业务实现类：
 */
@Service
public class MenuServiceImpl extends BaseServiceImpl<Menu> implements MenuService {
    @Autowired
    private MenuMapper menuMapper;

    @Override
    public List<Menu> menuTree() {
        //获取到所有的部门
        List<Menu> menus = menuMapper.findAll();
        //先，生成一个map
        HashMap<Long, Menu> map = new HashMap<>();
        //把所有的部门都装进map中，key为部门id，value为部门对象本身
        for (Menu menu : menus) {
            map.put(menu.getId(), menu);
        }
        //新建一个部门树，用于返回
        ArrayList<Menu> deptTree = new ArrayList<>();
        //再次遍历所有部门
        for (Menu menu : menus) {
            if (menu.getParentId() == null) {//判断为顶级部门
                deptTree.add(menu);//顶级部门就直接添加进去
            } else {//否则就为次级部门
                Long parent_id = menu.getParentId();//次级部门就需要获取他的父部门id
                Menu parentMenu = map.get(parent_id);
                if (parentMenu != null) {
                    parentMenu.getChildren().add(menu);
                }
            }
        }
        return deptTree;
    }
}
